//// 给你一个整数数组 nums ，数组中的元素 互不相同 。返回该数组所有可能的子集（幂集）。
////
//// 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
////
////
////
//// 示例 1：
////
////
//// 输入：nums = [1,2,3]
//// 输出：[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]
////
////
//// 示例 2：
////
////
//// 输入：nums = [0]
//// 输出：[[],[0]]
////
////
////
////
//// 提示：
////
////
//// 1 <= nums.length <= 10
//// -10 <= nums[i] <= 10
//// nums 中的所有元素 互不相同
////
//// Related Topics 位运算 数组 回溯 👍 1816 👎 0
//

package leetcode.editor.cn;

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;

// Java：子集
public class P78Subsets {
    public static void main(String[] args) {
        Solution solution = new P78Subsets().new Solution();
        // TO TEST
        int[] nums = {1, 2, 3};
        List<List<Integer>> subsets = solution.subsets(nums);
        System.out.println(subsets);
    }
    // leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        List<List<Integer>> result = new ArrayList<>();// 存放符合条件结果的集合
        LinkedList<Integer> path = new LinkedList<>();// 用来存放符合条件结果
        public List<List<Integer>> subsets(int[] nums) {
            subsetsHelper(nums, 0);
            return result;
        }

        private void subsetsHelper(int[] nums, int startIndex){
            result.add(new ArrayList<>(path));//「遍历这个树的时候，把所有节点都记录下来，就是要求的子集集合」。
            if (startIndex >= nums.length){ //终止条件可不加
                return;
            }
            for (int i = startIndex; i < nums.length; i++){
                path.add(nums[i]);
                subsetsHelper(nums, i + 1);
                path.removeLast();
            }
        }
    }
    // leetcode submit region end(Prohibit modification and deletion)

}
